import * as api from './api';
import {
  dict,
  compute,
  CreateCrudOptionsProps,
  CreateCrudOptionsRet,
  UserPageQuery,
  UserPageRes,
  EditReq,
  DelReq,
  AddReq,
} from '@fast-crud/fast-crud';
export default function ({ crudExpose }: CreateCrudOptionsProps): CreateCrudOptionsRet {
  const { crudBinding } = crudExpose;
  const pageRequest = async (query: UserPageQuery): Promise<UserPageRes> => {
    return await api.GetList(query);
  };
  const editRequest = async ({ form, row }: EditReq) => {
    if (form.id == null) {
      form.id = row.id;
    }
    return await api.UpdateObj(form);
  };
  const delRequest = async ({ row }: DelReq) => {
    return await api.DelObj(row.id);
  };

  const addRequest = async ({ form }: AddReq) => {
    return await api.AddObj(form);
  };

  return {
    crudOptions: {
      request: {
        pageRequest,
        addRequest,
        editRequest,
        delRequest,
      },
      actionbar: {
        buttons: {
          add: {
            show: false,
          },
          addRow: {
            show: true,
          },
        },
      },
      table: {
        editable: {
          mode: 'free',
          activeDefault: true,
          showAction: false,
        },
      },
      pagination: {
        pageSize: 5,
        pageSizes: [5, 10, 20, 50, 100],
      },
      columns: {
        id: {
          title: 'ID',
          type: 'number',
          form: {
            show: false,
          },
          column: { width: 80, align: 'center' },
        },
        disable: {
          title: '禁止编辑',
          type: 'text',
          column: {
            editable: {
              disabled: true, //也可以配置为方法，根据条件禁用或启用编辑
              // disabled: ({ column, index, row }) => {
              //   return index % 2 === 0;
              // }
            },
          },
        },
        radio: {
          title: '状态',
          search: { show: true },
          type: 'dict-radio',
          dict: dict({
            url: '/mock/dicts/OpenStatusEnum?single',
          }),
          form: {
            rule: [{ required: true, message: '请选择状态' }],
          },
        },
        name: {
          title: '姓名',
          type: 'text',
          form: {
            rule: [
              { required: true, message: '请输入姓名' },
              { min: 2, max: 10, message: '长度在 2 到 10 个字符' },
            ],
          },
        },
        address: {
          title: '地址',
          children: {
            province: {
              title: '省份',
              search: { show: true },
              type: 'text',
            },
            city: {
              title: '城市',
              search: { show: true },
              type: 'dict-select',
              dict: dict({
                value: 'id',
                label: 'text',
                data: [
                  { id: 'sz', text: '深圳', color: 'success' },
                  { id: 'gz', text: '广州', color: 'primary' },
                  { id: 'bj', text: '北京' },
                  { id: 'wh', text: '武汉' },
                  { id: 'sh', text: '上海' },
                ],
              }),
            },
          },
        },
      },
    },
  };
}
